package com.changgou.goods.controller;

import com.changgou.entity.PageResult;
import com.changgou.entity.Result;
import com.changgou.entity.StatusCode;
import com.changgou.goods.service.SkuService;
import com.changgou.goods.pojo.Sku;
import com.github.pagehelper.Page;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

import java.util.HashMap;
import java.util.List;
import java.util.Map;

@RestController
@CrossOrigin
@RequestMapping("/sku")
public class SkuController {


    @Autowired
    private SkuService skuService;

    /**
     * 查询全部数据
     *
     * @return
     */
    @GetMapping
    public Result findAll() {
        List<Sku> skuList = skuService.findAll();
        return new Result(true, StatusCode.OK, "查询成功", skuList);
    }

    /***
     * 根据ID查询数据
     * @param id
     * @return
     */
    @GetMapping("/{id}")
    public Result findById(@PathVariable String id) {
        Sku sku = skuService.findById(id);
        return new Result(true, StatusCode.OK, "查询成功", sku);
    }


    /***
     * 新增数据
     * @param sku
     * @return
     */
    @PostMapping
    public Result add(@RequestBody Sku sku) {
        skuService.add(sku);
        return new Result(true, StatusCode.OK, "添加成功");
    }


    /***
     * 修改数据
     * @param sku
     * @param id
     * @return
     */
    @PutMapping(value = "/{id}")
    public Result update(@RequestBody Sku sku, @PathVariable String id) {
        sku.setId(id);
        skuService.update(sku);
        return new Result(true, StatusCode.OK, "修改成功");
    }


    /***
     * 根据ID删除品牌数据
     * @param id
     * @return
     */
    @DeleteMapping(value = "/{id}")
    public Result delete(@PathVariable String id) {
        skuService.delete(id);
        return new Result(true, StatusCode.OK, "删除成功");
    }

    /***
     * 多条件搜索品牌数据
     * @param searchMap
     * @return
     */
    @GetMapping(value = "/search")
    public Result findList(@RequestParam Map searchMap) {
        List<Sku> list = skuService.findList(searchMap);
        return new Result(true, StatusCode.OK, "查询成功", list);
    }


    /***
     * 分页搜索实现
     * @param searchMap
     * @param page
     * @param size
     * @return
     */
    @GetMapping(value = "/search/{page}/{size}")
    public Result findPage(@RequestParam Map searchMap, @PathVariable int page, @PathVariable int size) {
        Page<Sku> pageList = skuService.findPage(searchMap, page, size);
        PageResult pageResult = new PageResult(pageList.getTotal(), pageList.getResult());
        return new Result(true, StatusCode.OK, "查询成功", pageResult);
    }


    //这是一个什么方法,和feign里面那个方法有什么联系,这个spuid是feign传递过来的吗,他这个getmapping地址怎么和feign中的地址一样
    //这是方法是子feign里面调用了
    @GetMapping("/spu/{spuId}")
    public List<Sku> findSkuListBySpuId(@PathVariable("spuId") String spuId) {
        //为什么要创建一个map装spuid????,传递过来的数据是什么类型的
        //这是多条件查询,所以需要用map??????
        Map<String, Object> searchMap = new HashMap<>();

        //这个判断表示,如果all不等于spid就执行下面的语句
        //如果输入的参数是all,那么就不执行这个if,就相当于是全查了
        if (!"all".equals(spuId)) {
            searchMap.put("spuId", spuId);
        }
        searchMap.put("status", "1");

        //根据这个条件查询出一个List,因为一个spuid对应多个Sku,他们是一对多的关系
        List<Sku> skuList = skuService.findList(searchMap);

        return skuList;
    }

    @GetMapping("/spu/{spuId}/{page}")
    public PageResult<Sku> findSkuPageBySpuId(@PathVariable("spuId") String spuId, @PathVariable("page") Integer page) {
        Map<String, Object> searchMap = new HashMap<>();

        if (!"all".equals(spuId)) {
            searchMap.put("spuId", spuId);
        }
        searchMap.put("status", "1");
        Page<Sku> skuPage = skuService.findPage(searchMap, page, 1000);
        // 在PageResult 中添加一个 pages总页数字段
        PageResult<Sku> pageResult = new PageResult(skuPage.getTotal(), skuPage.getResult(), skuPage.getPages());

        return pageResult;
    }

}
